<template>
	<view class="content reg-page">
		<view class="input-group">
			<view class="input-row border-bottom-1px" @click="uploadImgs">
				<view class="header">
					<text class="title">头像</text>
					<text class="tip">上传真实头像，BOSS回复率翻倍哦！</text>
				</view>
				<view class="head-img"><image :src="userInfo.avatar || '/static/img/head.png'"></image></view>
			</view>
			<view class="input-column border-bottom-1px">
				<text class="title">姓名</text>
				<view class="input-item">
					<m-input type="text" clearable v-model="userInfo.name" placeholder="请输入姓名" :maxLength="30"></m-input>
					<!-- <text class="yzb yzb-next"></text> -->
				</view>
			</view>

			<view class="input-row border-bottom-1px">
				<text class="title">性别</text>
				<radio-group @change="radioChange">
					<label class="radio">
						<radio value="1" checked="true" />
						男
					</label>
					<label class="radio">
						<radio value="2" />
						女
					</label>
				</radio-group>
			</view>

			<view class="input-column border-bottom-1px">
				<text class="title">参加工作时间</text>
				<view class="picker">
					<picker mode="date" :value="userInfo.timeToWork" :start="workStart" :end="workEnd" @change="bindDateChange">
						<view class="uni-input">{{ userInfo.timeToWork }}</view>
					</picker>
					<text class="yzb yzb-next"></text>
				</view>
			</view>

			<view class="input-column border-bottom-1px">
				<text class="title">最高学历</text>
				<view class="picker">
					<picker @change="bindPickerChange" :value="userInfo.education" :range="array">
						<!-- <view class="uni-input">{{ userInfo.education}}</view> -->
						<input class="padding-10" placeholder="请选择学历" :value="userInfo.education" />
					</picker>
					<text class="yzb yzb-next"></text>
				</view>
			</view>

			<view class="input-column border-bottom-1px">
				<text class="title">出生年月</text>
				<view class="picker">
					<picker mode="date" :value="userInfo.birthday" :start="startDate" :end="endDate" @change="bindBirthdayChange">
						<view class="uni-input">{{ userInfo.birthday }}</view>
					</picker>
					<text class="yzb yzb-next"></text>
				</view>
			</view>
		</view>

		<view class="btn-row"><button type="primary" class="primary" @tap="update">保存</button></view>
	</view>
</template>

<script>
import { mapState } from 'vuex';
import mInput from '@/components/m-input/m-input.vue';
import graceChecker from '@/common/graceChecker.js';
import formRuleConfig from '@/config/formRule.config.js';
import uploadImage from '@/common/ossutil/uploadFile';
export default {
	components: {
		mInput,
	},
	computed: {
		...mapState(['openId', 'customerInfo']),
		startDate() {
			return this.getDate('start');
		},
		endDate() {
			return this.getDate('end');
		},
		workStart() {
			return this.getDate('work-start');
		},
		workEnd() {
			return this.getDate('work-end');
		}
	},

	data() {
		const currentDate = this.getDate({
			format: true
		});
		return {
			date: currentDate,
			array: ['高中以下', '高中', '中专/技校', '大专', '本科', '硕士', '博士'],
			tmpImageUrl:'',
			userInfo:{
				avatar:'',
				birthday:currentDate,
				timeToWork:currentDate,
				name:'',
				sex:1,
				education:null,
			}
		};
	},
	onLoad() {
		this.getResumeInfo();
	},
	methods: {
		
		async getResumeInfo(){
			let re = await this.$apis.getResumeInfo();
			if(re){
				this.userInfo=re;
				console.log("getResumeInfo",this.userInfo);
			}
		},
		
		bindPickerChange: function(e) {
			this.userInfo.education = this.array[e.target.value];
		},
		
		bindBirthdayChange: function(e) {
			this.userInfo.birthday = e.target.value;
		},
		
		bindDateChange: function(e) {
			this.userInfo.timeToWork = e.target.value;
		},
		
		// 选择图片
		uploadImgs() {
			let that = this;
			uni.chooseImage({
				success(res) {
					let tempFilePaths = res.tempFilePaths;
					that.tmpImageUrl = tempFilePaths[0];
					that.uploadFile();
				}
			});
		},
		
		// 上传图片
		uploadFile() {
			uni.showLoading({
				title: '图片上传中'
			});
			let that=this;
			uploadImage(0,this.tmpImageUrl, 'job/user/', result => {
				console.log('图片上传结果：', result);
				that.userInfo.avatar = result;
				uni.hideLoading();
			});
		},
		
		getDate(type) {
			const date = new Date();
			let year = date.getFullYear();
			let month = date.getMonth() + 1;
			let day = date.getDate();
			if (type === 'start') {
				year = year - 60;
			}else if(type === 'work-start') {
				year = year - 40;
			}else if(type === 'work-end') {
				// year = year;
			}else if(type === 'end') {
				year = year - 18;
			}
			month = month > 9 ? month : '0' + month;
			day = day > 9 ? day : '0' + day;
			return `${year}-${month}-${day}`;
		},

		// 更新
		async update() {
			let checkRes = graceChecker.check(this.userInfo, formRuleConfig.regResumeBaseRule);
			if (!checkRes) {
				uni.showToast({
					title: graceChecker.error,
					icon: 'none'
				});
				return;
			}
			let res = await this.$apis.updateResumeBasic(this.userInfo);
			if(res){
				uni.navigateBack({
					delta:1
				})
			}
		},
	}
};
</script>

<style lang="scss" scoped>
.input-group {
	border-radius: 10upx;
	margin-top: 10upx;
	overflow: hidden;
}

.input-row {
	display: flex;
	flex-direction: row;
	position: relative;
	background: #fff;
	justify-content: space-between;
	align-items: center;
	padding: 15upx 10upx;
}

.input-row .title {
	width: 25%;
	padding: 20upx 0;
	padding-left: 20upx;
	line-height: 50upx;
}

.border-bottom-1px {
	position: relative;

	&::after {
		position: absolute;
		z-index: 1;
		right: 0;
		bottom: 0;
		left: 20upx;
		height: 1upx;
		content: '';
		-webkit-transform: scaleY(0.5);
		transform: scaleY(0.5);
		background-color: #e2e2e2;
	}
}

.header {
	display: flex;
	flex-direction: column;
	.tip {
		font-size: $uni-font-size-sm;
		color: $font-color-666;
		margin-left: 20upx;
	}
}

.head-img {
	margin-right: 15upx;
	image {
		width: 160upx;
		height: 160upx;
		border-radius: 50%;
	}
}

radio-group {
	margin-right: 10upx;
}

.radio {
	margin-left: 20upx;
}

.input-column {
	display: flex;
	flex-direction: column;
	background-color: $bgcolor_white;
	padding: 30upx 20upx 10upx 20upx;

	.title {
		margin-left: 10upx;
	}

	.input-item {
		display: flex;
		flex-direction: row;
		justify-content: space-between;
		align-items: center;
	}

	.picker {
		padding: 30upx 0 20upx 0;
		margin-left: 10upx;
		position: relative;
		picker {
			font-size: $uni-font-size-lg;
			width: 100%;
			position: absolute;
		}
	}
	.yzb-next {
		float: right;
		color: $font-color-999;
	}
}

.content {
	background: $bgcolor_white;
}

.btn-row {
	position: fixed;
	bottom: 10upx;
	width: 100%;
	box-sizing: border-box;
	button {
		background-color: $main-color;
		height: 90upx;
		line-height: 90upx;
		font-size: $font-size-34;
	}
}
</style>
